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DETAILED ACTION 



1. 



A request for continued examination under 37 CFR 1.114, including the fee set forth in 



37 CFR 1. 17(e), was filed in this application after final rejection. Since this application is 
eligible for continued examination under 37 CFR 1. 1 14, and the fee set forth in 37 CFR 1.17(e) 
has been timely paid, the finality of the previous Office action has been withdrawn pursuant to 
37 CFR 1.114. Applicant's submission filed on July 19, 2005 has been entered. Claims 1-20 are 
pending. 

Response to Amendment 

2. The rejection of claims 1-20 under 35 U.S.C 1 12, second paragraph, has been withdrawn 
in view of Applicant's amendment. 

Response to Arguments 

3. Applicant's arguments have been fully considered but they are not persuasive. 

As set forth below, Barritz teaches the new limitation recited in claims 1,15 and 18 that 
the "duration of storage [is] sufficient to allow data collected during an operating session to be 
retrieved and used after termination of the session." 

The arguments reiterated from Applicant's previous response filed on November 15, 
2004 were addressed in the final Office action mailed on April 19, 2005. 



Claim Rejections - 35 USC §103 



4. 



The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 



obviousness rejections set forth in this Office action: 
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(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

5. Claims 1-20 are rejected under 35 U.S.C. 103(a) as being unpatentable over U.S. Patent 
No. 6,049,798 to Bishop et al. (art of record, "Bishop"), in view of U.S. Patent No. 5,590,056 to 
Barritz (art of record, "Barritz"), in view of U.S. Patent No. 5,247,675 to Farrell et al. (art of 
record, "Farrell"), in view of U.S. Patent No. 5,870,604 to Yamagishi (art of record, 
"Yamagishi"). 

With respect to claim 1 (currently amended), Bishop discloses a method of capturing 
operating software scheduling information during execution of operating software (see, for 
example, the abstract, which shows capturing internal resource information such as CPU and 
memory availability or utilization, i.e. scheduling information, in real-time, i.e. during execution 
of the operating software), the method comprising the steps of: 

(a) compiling operating software scheduling information capture software as part of the 
operating system (see, for example, column 11, lines 1-4, which shows a service of the operating 
system, inherently compiled, that is used for capturing event traces of process activity, i.e. 
scheduling information). 

Although Bishop discloses recording the data for a certain amount of time in order to 
provide past records, i.e. a history of events (see, for example, column 22, lines 18-22), and 
discloses identifying each task by process ED and process name (see, for example, FIG. 13 A), 
Bishop does not expressly disclose the limitation wherein the operating software scheduling 
information capture software is operative to record a history of the operating software events as 
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they occur, information related to the history being organized and stored as operating software 
program scheduling information relating to interactions between the operating system software 
and each of the programs and tasks managed by the operating system software. 

However, Barritz discloses monitoring events as they occur and recording an event 
history log (see, for example, FIG. 5 and column 6, lines 54-57), in which the recorded 
information comprises job scheduling information for each module or task managed by the 
scheduler, i.e. the operating system software (see, for example, column 6, lines 58-64), so as to 
identify software usage patterns (see, for example, column 2, line 63 to column 3, line 4). 

It would have been obvious to one of ordinary skill in the art at the time the invention 
was made to supplement the capture system of Bishop with the event history features taught by 
Barritz, for the purpose of identifying software usage patterns. 

Although Bishop discloses monitoring and capturing the information to improve the 
efficiency of a computer system (see, for example, column 3, lines 12-33), Bishop does not 
expressly disclose the limitation wherein the scheduling information includes indications of 
relative priorities of programs and tasks. 

However, Farrell discloses scheduling information that indicates the relative priorities of 
threads or tasks (see, for example, thread state descriptor 19 in FIG, 2, and column 4, line 62 to 
column 5, line 12), which is used to optimize program execution (see, for example, column 2, 
lines 19-24). 

It would have been obvious to one of ordinary skill in the art at the time the invention 
was made to supplement the information captured by Bishop with the relative priorities of 
programs and tasks, such as taught by Farrell, in order to further improve execution efficiency. 
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Bishop further discloses the limitation wherein the scheduling information includes 
indications of transfers of control from lower priority to higher priority tasks (see, for example, 
FIG. 13A, which shows trace records for process switches, i.e. transfers of control among tasks, 
and column 10, lines 62-67, which shows that the tasks have lower and higher priority levels). 

Although Bishop discloses monitoring and capturing the information to improve the 
efficiency of a computer system (see, for example, column 3, lines 12-33), Bishop does not 
expressly disclose the limitation wherein the scheduling information includes identification of 
tasks waiting for execution at the occurrence of each software event. 

However, Yamagishi discloses scheduling information that identifies the number of jobs 
or tasks waiting for execution (see, for example, operation status table 9 and heading 92 in FIG. 
3). A CPU monitor captures the information from a job scheduler (see, for example, column 3, 
lines 59-65) to distribute the load among processors, thereby improving efficiency (see, for 
example, column 2, lines 36-39). 

It would have been obvious to one of ordinary skill in the art at the time the invention 
was made to supplement the information captured by Bishop with the tasks waiting for 
execution, such as taught by Yamagishi, in order to further improve execution efficiency. 

Bishop further discloses the steps of: 

(b) invoking operating software scheduling information capture (see, for example, 
column 20, line 55 to column 21, line 4, which shows a procedure for invoking the capture of the 
data); and 

(c) recording operating software scheduling information for relatively long duration 
storage in order to permit review of the scheduling information by a user (see, for example, 
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column 22, lines 18-22, which shows recording the data for a relatively long duration for review 
of past records by a user). 

Barritz further discloses the limitation wherein the duration of storage is sufficient to 
allow data collected during an operating session to be retrieved and used after termination of the 
session (see, for example, column 10, lines 28-44, which shows that the information is recorded 
to a log for storage, and column 8, lines 43-63, which shows that the information is later 
retrieved from the log after one or more operating sessions to produce statistical reports). 

With respect to claim 2 (original), Bishop further discloses the limitation wherein the 
operating software scheduling information capture procedure is invoked on an operating 
software task switch (see, for example, column 14, lines 14-15 and line 55 to column 15, line 1 1, 
which shows that mode switches and thread dispatches, i.e. task switches, can invoke the capture 
of scheduling information). 

With respect to claim 3 (original), Bishop further discloses the limitation wherein the 
operating software scheduling information recorded includes information updated or maintained 
by the operating software in relation to the scheduling of a program (see, for example, FIG. 13 A, 
which shows trace records that include execution time and interrupt time, information 
maintained by the operating system in relation to scheduling). 

With respect to claim 4 (original), Bishop in view of Barritz, Farrell and Yamagishi 
further discloses the limitation wherein the operating software scheduling information recorded 
includes task identification, task priority, and task run-time length (see, for example, Bishop, 
FIG. 13 A, which shows trace records that include the process ID, i.e. task identification, and the 
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execution time, i.e. run-time length; also see, for example, Farrell, FIG. 2, which shows a thread 
state descriptor that includes the thread or task priority). 

With respect to claim 5 (original), Bishop in view of Barritz, Farrell and Yamagishi 
further discloses the limitation wherein the operating software scheduling information includes a 
task waiting count (see, for example, Yamagishi, FIG. 3, which shows an operation status table 
that includes the number of jobs waiting for execution, i.e. a task waiting count). 

With respect to claim 6 (original), Bishop further discloses the limitation wherein the 
operating software scheduling information is recorded to a ledger (see, for example, column 20, 
lines 36-37 and 50-52, which shows that the data is initially recorded to a buffer or ledger). 

With respect to claim 7 (original), Bishop further discloses the limitation wherein the 
ledger is at least one of a circular or fixed length ledger (see, for example, column 21, lines 23- 
26, which shows that data is discarded from the pipe if it is not read quickly enough, i.e. because 
the buffer is a circular ledger having a fixed length). 

With respect to claim 8 (original), Bishop further discloses the limitation wherein the 
scheduling information includes at least one of the number of program schedules, program 
preempts, and interrupts (see, for example, column 14, lines 14-15 and 35-45, which shows that 
interrupts are recorded). 

With respect to claim 9 (original), Bishop further discloses the limitation wherein the 
scheduling information includes at least one of the highest priority attained, program identity, 
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and length of run-time (see, for example, column 21, lines 49-52, which shows that the process 
name, i.e. the program identity, is included in the captured scheduling information). 

With respect to claim 10 (original), Bishop further discloses the limitation wherein the 
scheduling information includes at least one of the lowest priority attained, program identity, and 
length of run-time (see, for example, column 21, lines 49-52, which shows that the process name, 
i.e. the program identity, is included in the captured scheduling information). 

With respect to claim 1 1 (original), Bishop further discloses the limitation wherein the 
scheduling information includes at least one of the number of times in the idle loop and length of 
run-time (see, for example, FIG. 13 A, which shows trace records that include the execution time, 
i.e. the length of run-time). 

With respect to claim 12 (original), Bishop further discloses the limitation wherein the 
scheduling information includes a sequential record of at least one of scheduled programs, 
priorities, and events (see, for example, column 15, lines 54-64, which shows that events are 
matched with timing information to compose a sequential record of events). 

With respect to claim 13 (original), Bishop in view of Barritz, Farrell and Yamagishi 
further discloses the limitation wherein the scheduling information includes at least one of the 
number and identity of programs waiting to run (see, for example, Yamagishi, FIG. 3, which 
shows an operation status table that includes the number of jobs waiting to run). 

With respect to claim 14 (original), Bishop further discloses the limitation wherein the 
operating software scheduling information capture is invoked on an event occurrence (see, for 
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example, column 14, lines 14-15 and 55-60, which shows that events such as a mode switch can 
invoke the capture of scheduling information). 

With respect to claim 15 (currently amended), the limitations recited in the claim are 
analogous to those of claim 1 (see the rejection of claim 1 above). 

With respect to claim 16 (original), Bishop further discloses the limitation wherein said 
operating software scheduling information capture software is not resident on an external device 
(see, for example, column 4, lines 32-34, which shows that the software can be internal to the 
system, and column 22, lines 59-63, which shows that external hardware is not needed). 

With respect to claim 17 (original), Bishop further discloses the limitation wherein said 
operating software scheduling information capture software is not a separate task scheduled by 
an operating software scheduler (see, for example, column 1 1, lines 1-10 and 30-35, which 
shows that the information capture is performed by a device driver, i.e. not by a separate task 
scheduled by a operating software scheduler). 

With respect to claim 18 (currently amended), the limitations recited in the claim are 
analogous to those of claim 1 (see the rejection of claim 1 above). Bishop further discloses a 
processor for receiving and transmitting data (see, for example, CPU 190 in FIG. 14) and a 
memory coupled to the processor (see, for example, RAM 194 in FIG. 14), the memory storing 
instructions to be executed by the processor. 

With respect to claim 19 (original), Bishop further discloses the limitation wherein said 
operating system scheduling information capture software is internally processed on said 
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processor (see, for example, column 4, lines 32-34, which shows that the software can be internal 
to the system). 

With respect to claim 20 (original), Bishop further discloses the limitation wherein said 
operating software scheduling information capture software is not a separate task scheduled by 
an operating software scheduler (see, for example, column 11, lines 1-10 and 30-35, which 
shows that the information capture is performed by a device driver, i.e. not by a separate task 
scheduled by a operating software scheduler). 

Conclusion 

6. The prior art made of record and not relied upon is considered pertinent to Applicant's 
disclosure. U.S. Patent No. 5,761,091 to Agrawal et al. discloses a method and system for 
reducing the errors in the measurements of resource usage in computer system processes and 
analyzing process data with subsystem data. U.S. Patent No. 6,377,907 to Waclawski discloses a 
system and method for collating Unix performance metrics. 

7. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Michael J. Yigdall whose telephone number is (571) 272-3707. 
The examiner can normally be reached on Monday through Friday from 7:30am to 4:00pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Tuan Q. Dam can be reached on (571) 272-3695. The fax phone number for the 
organization where this application or proceeding is assigned is 571-273-8300. 
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Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private 
PAIR system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 

M y Michael J. Yigdall 

^ Examiner 
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